iOS中使用Protocol Buffer
简介
Protocol Buffer(简称Protobuf或PB)是由Google推出的一种数据交换格式.
与传统的XML和JSON不同的是,它是一种二进制格式,免去了文本格式转换的各种困扰,并且转换效率也是非常快,由于它的跨平台、跨编程语言的特点,让它越来越普及,尤其是网络数据交换方面日趋成为一种主流.
原理
对于json和xml最终在网络传输时都是以字符串转二进制的进行传输的,使用的是utf8编码格式,而PB在编码与解码上进行了改进,使数据包更小,所以我觉得可以把他当做一种压缩格式.这里有一篇关于原理的博文,感兴趣大家可以去看一看 Protocol Buffer 序列化原理大揭秘 - 为什么Protocol Buffer性能这么好?
安装
我们需要安装PB的编译器,将我们用PB语法格式创建的对象转化为OC或Swift的对象,原来PB只支持Python,Java,C++,现在新的版本支持OC,Swift需要我们额外配置一下,期待以后的更新吧.这是github的链接
解压缩后,cd到其目录下执行下面的终端命令进行安装
1 | $ ./autogen.sh |
安装结束后,执行 protoc –version ,若有显示版本号,则表明安装成功.若是要试用Swift则需要
1 | $ brew install protobuf-swift |
接下来就是创建proto文件,将其翻译为OC或Swift,所以先了解proto的语法
语法
接下来我只介绍些常用语法,这里有介绍语法比较详细的博文 这是一份很有诚意的Protocol Buffer语法详解 Protobuf3 语法指南
1 | //表示使用的是PB3的语法 |
接下来是关于PB的数据结构类型,因为要控制数据编码后大小,所以类型比较多
对应到iOS的OC和Swift中,上面就包含了所需的基本数据类型了,一个message,其实就可以看做一个字典.至于数组就比较特别了,而是要在基本的数据结构前 加上可复用的修饰符 repeated 就如上面的friends一样.
编译转换
OC
1 | 进入proto文件目录 执行下面的命令 |
Swift
1 | 进入proto文件目录 执行下面的命令 |
这样就得到了,翻译后所需的类文件了,接下来就要到项目中集成了
项目集成
在项目中使用PB需要使用第三方库,可以使用CocoaPod集成
1 | OC: |
对于OC版本,拖进项目后要再做一些额外处理,生成的是MRC环境下的代码,需要设置一下, 其次再编译后会报一些错误,据我所知的处理方案是将其注释掉(我了解到的是该方法在C99后失效了,至于为何这里还有,我也很无奈ㄟ( ▔, ▔ )ㄏ,到Github上反应了).这样就可以使用了. 然后就是PB的序列化与反序列化
序列化与反序列化
OC
1 | Person* p = [Person new]; |
运行结果:
1 | PB --> 16 JSON --> 49 |
Swift
1 | //创建新的对象,通过Builder来进行创建,赋值. |
最后说一说PB的优缺点
优缺点
优点
1 | 1,数据压缩效果好,序列化反序列速度快 |
缺点
1 | 1,可读性行差(在代码中) |
综上:个人觉得该方案适用于大量频繁的数据交流业务中,如IM
若有不准确的地方,欢迎大家指正